<template>
  <el-container>
    <el-header>
      <div class="left-panel">
        <el-button type="primary" icon="el-icon-plus" @click="add"></el-button>
        <el-button type="primary" plain :disabled="selection.length != 1" @click="permission">分配资源</el-button>
      </div>
      <div class="right-panel">
        <div class="right-panel-search">
          <el-input v-model="search.roleName" style="width: 170px;" placeholder="角色名称" clearable></el-input>
          <el-button type="primary" icon="el-icon-search" @click="upsearch"></el-button>
        </div>
      </div>
    </el-header>
    <el-main class="nopadding">
      <scTable ref="table" :apiObj="apiObj" row-key="id" @selection-change="selectionChange" stripe>
        <el-table-column type="selection" width="50"></el-table-column>
        <!-- <el-table-column label="#" type="index" width="50"></el-table-column> -->
        <el-table-column label="角色名称" prop="roleName" width="200"></el-table-column>
        <el-table-column label="角色别名" prop="roleAlias" width="150"></el-table-column>
        <el-table-column label="角色状态" prop="status" width="150">
          <template #default="scope">
            <el-tag v-if="scope.row.status == 0" type="success">启用</el-tag>
            <el-tag v-if="scope.row.status == 1" type="danger">停用</el-tag>
          </template>
        </el-table-column>
        <el-table-column label="创建时间" prop="createTime" width="180"></el-table-column>
        <el-table-column label="操作" fixed="right" align="right" width="120">
          <template #default="scope">
            <el-button-group>
              <!-- <el-button text type="warning" size="small" @click="permission(scope.row, scope.$index)">授权
              </el-button> -->
              <el-button  size="small" @click="table_edit(scope.row, scope.$index)">编辑
              </el-button>
              <el-popconfirm title="确定删除当前记录吗？" confirm-button-type="danger" confirm-button-text="确定"
                             @confirm="table_del(scope.row, scope.$index)">
                <template #reference>
                  <el-button type="danger" size="small">删除</el-button>
                </template>
              </el-popconfirm>
            </el-button-group>
          </template>
        </el-table-column>

      </scTable>
    </el-main>
  </el-container>

  <save-dialog v-if="dialog.save" ref="saveDialog" @success="handleSaveSuccess" @closed="dialog.save = false">
  </save-dialog>

  <el-drawer v-model="dialog.permission" :size="380" :title="permissionTitle" direction="rtl" destroy-on-close>
    <permission-dialog ref="permissionDialog" @closeDrawer="dialog.permission = false"></permission-dialog>
  </el-drawer>

  <el-drawer v-model="dialog.user" :size="1010" :title="userTitle" direction="rtl" destroy-on-close >
    <user-dialog ref="userDialog" @closeDrawer="dialog.user = false"></user-dialog>
  </el-drawer>

</template>

<script>
import saveDialog from './save'
import permissionDialog from './permission'

export default {
  name: 'role',
  components: {
    saveDialog,
    permissionDialog
  },
  data() {
    return {
      dialog: {
        save: false,
        permission: false,
        user:false
      },
      apiObj: this.$API.system.role.list,
      selection: [],
      permissionTitle: "",
      userTitle:'',
      search: {
        roleName: null
      }
    }
  },
  methods: {
    //添加
    add() {
      this.dialog.save = true
      this.$nextTick(() => {
        this.$refs.saveDialog.open()
      })
    },
    //编辑
    table_edit(row) {
      this.dialog.save = true
      this.$nextTick(() => {
        this.$refs.saveDialog.open('edit').setData(row)
      })
    },
    //权限设置
    permission() {
      this.dialog.permission = true
      var row = this.selection[0]
      console.log(row)
      this.permissionTitle = '分配资源 [角色:' + row.roleName + ']'
      this.$nextTick(() => {
        this.$refs.permissionDialog.open(row)
      })
    },
    //选择用户
    user(){
      this.dialog.user = true
      var row = this.selection[0]
      this.$TOOL.session.set("TEMP_ROLE_ID", row.id)
      this.userTitle = '选择人员 [角色:' + row.name + ']'
      this.$nextTick(() => {
        this.$refs.userDialog.open()
      })
    },
    //删除
    async table_del(row) {
      var res = await this.$API.system.role.delete.delete(row.id);
      if (res.code == 200) {
        this.$refs.table.refresh()
        this.$message.success("删除成功")
      } else {
        this.$alert(res.msg, "提示", { type: 'error' })
      }
    },
    //表格选择后回调事件
    selectionChange(selection) {
      this.selection = selection;
    },
    //搜索
    upsearch() {
      this.$refs.table.reload(this.search)
    },
    //本地更新数据
    handleSaveSuccess(data, mode) {
      if (mode == 'add') {
        this.$refs.table.refresh()
      } else if (mode == 'edit') {
        this.$refs.table.refresh()
      }
    }
  }
}
</script>

<style>
</style>
